### Files needed



## Make a folder and keep these file – run.tcl



## Keep this under RTL folder counter\_4b.v

- `timescale 1ns/1ps
- module counter\_4b(lclk,lrst,count);
- input lclk,lrst;
- output reg [3:0] count;
- always @(posedge lclk or posedge lrst)
- begin
- if(lrst)
- count=0;
- else
- count=count+1;
- end
- endmodule

## Under constraints counter\_4b.sdc

- create\_clock -name lclk -period 8.0 -waveform {0 4} [get\_ports "lclk"]
- set\_clock\_transition -rise 0.1 "lclk"
- set\_clock\_transition -fall 0.1 "lclk"
- set\_clock\_uncertainty 0.1 "lclk"
- set\_input\_delay -max 1 [get\_ports "lrst"] -clock [get\_clocks "lclk"]
- set\_output\_delay -max 1 [get\_ports "count"] -clock [get\_clocks "lclk"]

### Start from cadence terminal

- Cmd >csh
- Cmd >source cshrc
- Go to design folder
- cmd>genus –f run.tcl
- Cmd>gui\_show
- Click + select schematic
- You will see sch—similar to this `
- Cmd> innovus
- New window will open... leave it as is

#### Genus(TM) Synthesis Solution 23.1 - /home/2 File DFT Floorplan Power Timing Tools Windows Help Design Browser <u>L</u>ayout × <u>L</u>ayout StdCells <u>S</u>chematic HDL Viewer ⊟ Hier Cell - counter Design Browser ⊕ Terms (6) Object Attributes ⊕- Nets (13) ± StdCells (8)



## Create this file under workarea Default.globals

- set conf\_qxconf\_file {NULL}
- set conf\_qxlib\_file {NULL}
- set defHierChar {/}
- set init\_design\_settop 0
- set init\_gnd\_net {VSS}
- set init\_pwr\_net {VDD}
- set init\_lef\_file {"../LEF/gsclib045\_tech.lef"
   "../LEF/gsclib045\_macro.lef"}

### Create this file in workarea Default.view

- # Version: 1.0 MMMC View Definition File
- # Do Not Remove Above Line
- create\_library\_set -name MAX\_lib -timing "../LIB/slow.lib"
- create\_library\_set -name MIN\_lib -timing "../LIB/fast.lib"
- create\_constraint\_mode -name Constraints -sdc\_files {counter\_4b\_m.sdc}
- create\_constraint\_mode -name Constraints2 -sdc\_files {counter\_4b\_m.sdc}
- create timing condition -name worst t-library sets MAX lib
- create\_timing\_condition -name best\_t -library\_sets MIN\_lib
- create\_delay\_corner -name worst -timing\_condition {worst\_t}
- create\_delay\_corner -name best -timing\_condition {best\_t}
- create\_analysis\_view -name Worst\_delay -constraint\_mode {Constraints} -delay\_corner {worst}
- create\_analysis\_view -name Best\_delay -constraint\_mode {Constraints2} -delay\_corner {best}
- set\_analysis\_view -setup {Worst\_delay} -hold {Best\_delay}

## On innovus terminal copy past these

• cmd>source Default.globals

## Now Import design (\_m.v is in the project folder not output folder)



Seq is important

Do not click this
Else you have to create the file aga







n System 23.13 - /home/2024ht08533\_wilp.t orpl<u>a</u>n Po<u>w</u>er <u>P</u>lace EC<u>O</u> <u>C</u>lock <u>R</u>oute <u>T</u>imin Connect Global Nets... Multiple Supply Voltage Power Planning Power Analysis Rail Analysis Packag<u>e</u> Repor<u>t</u> Generate Thermal Result...

## VDD and VSS to be added separately



### Add net VSS VDD rest leave as is



### Add net VSS VDD rest leave as is



### Add net VSS VDD rest leave as is





#### 3.13 - /home/2024ht08533\_wilp.bits-pilani.ac./c















## Zoom in and out you will see small ckt



## Timing report\_timing = pre\_cts



## Timing -report\_timing -pre\_cts works



- On innovus command prompt type
- Cmd> report\_area
- Cmd>report\_power

## Otimization – this will run for some time – just wait





## Copy this on innovus\_command line – does not work still

- create\_route\_rule -width {M1: 0.12 M2 0.14 M3 0.14 M4 0.14 M5 0.14 M6 0.14 M7 0.14 M8 0.14 M9 0.14} -spacing {M1 0.12 M2 0.14 M3 0.14 M4 0.14 M5 0.14 M6 0.14 M7 0.14 M8 0.14 M9 0.14} -name 2w2s
- create\_route\_type -name clkroute -route\_rule 2w2s -bottom\_preferred\_layer M5 top\_preferred\_layer M6
- set\_ccopt\_property route\_type clk route -net\_type trunk
- set\_ccopt\_property route\_type clkroute -net\_type leaf
- set\_ccopt\_property buffer\_cells {CLKBUFX8 CLKBUFX12}
- set\_ccopt\_property inverter\_cells {CLKINVX8 CLKINVX12}
- set\_ccopt\_property clock\_gating\_cells TLATNTSCA\*
- create\_ccopt\_clock\_tree\_spec -file ccopt.spec

## Next – does not work still for completeness sake

• Cmd>source ccopt.spec

# Since previous setup doe not work as to use default setup When u say okay you will see clock tree







## Post CTS setup and hold—you should see log







```
|NumPaths=12,Time=8946 microseconds
Hold views included:
Best_delay
                   | all | reg2reg | default |
           WNS (ns): | 0.081 | 0.081 | 0.295
           TNS (ns): | 0.000
                             0.000 | 0.000
    Violating Paths:|
          All Paths: 12
Density: 0.591%
Routing Overflow: 0.00% H and 0.00% V
Reported timing to dir timingReports
Total CPU time: 0.51 sec
Total Real time: 1.0 sec
Total Memory Usage: 3287.546875 Mbytes
*** time_design #3 [finish] () : cpu/real = 0:00:00.5/0:00:00.6 (0.8), totSession cpu/real = 0:02:41.5/0:40:38
```

- Cmd> report\_area
- Cmd>report\_power

## Routing optimization – will take some time for running





## Post routing setup /hold/area /power report



## Logs available



Save design and netlist & gds.. Gives some error.. Just ingoring for the time